分享Laravel是怎么操作宝塔面板API-观热点

来源:php中文网 | 2022-12-29 16:50:42 |


(资料图片仅供参考)

本文由Laravel教程栏目给大家介绍laravel+宝塔面板的相关知识,主要给大家分享Laravel是怎么操作宝塔面板API,下面就带大家一起来看看,希望对需要的朋友有所帮助!

Laravel 操作宝塔面板 API

不一样的地方根据自身业务修改!!!

其他的接口请查看官方文档:https://www.bt.cn/api-doc.pdf。

代码如下:

<?phpnamespace App\Http\Controllers\Custom;use App\Http\Controllers\Controller;use Illuminate\Support\Facades\Http;/** * 除了 AddSite GetSSL GetFileBody 外  其他都有返回 "msg" * 返回状态 "status" => true/false  "msg" => "申请成功!" * 官方API文档  https://www.bt.cn/api-doc.pdf */class BtPanel extends Controller{    /**     * 发送请求     * @param string $path /data?action=getData&table=sites 请求路径     * @param array $query 请求参数     */    private function sendRequest(string $path, array $query)    {        // 宝塔面板秘钥        $secretKey = config("custom.bt.key");        // 宝塔面板地址 http://xxx.xxx.xxx:2222 填写至端口即可        $panelPath = config("custom.bt.panel_path");        $time = time();        $response = Http::withOptions(["verify" => false])            ->retry(2, 5000) // !!!这里时间不适用于 GetApplyCert 接口            ->attach("cookie", $secretKey, "bt.cookie") // 随便传东西就行            ->post($panelPath . $path, array_merge([                "request_token" => md5($time . "" . md5($secretKey)),                "request_time" => $time            ], $query))            ->json();        return $response ?: false;    }    /**     * 查询网站     * @param string|null $search 需要搜索的关键词     * @return array|false     */    public function SiteSearch(string $search = null)    {        $search = $search ?: config("custom.bt.domain");        $response = $this->sendRequest("/data?action=getData&table=sites", [            "limit" => 5,            "search" => $search        ]);        // 获取失败        if (!isset($response["data"])) return false;        // 不允许出现相似的网站名        if (count($response["data"]) != 1) return false;        $site = $response["data"][0];        return [            "id" => $site["id"],            "name" => $site["name"],            "path" => $site["path"],            "ps" => $site["ps"],            "php" => str_replace(".", "", $site["php_version"])        ];    }    /**     * 创建网站     * !!!PS: 使用API创建网站时  最好 不要创建相似网站名的网站  不然查询时有些麻烦     * @param string $domain 网站域名     * @param [type] json webname        网站域名     * @param [type] string path         网站路径 /www/wwwroot/www.baidu.com     * @param [type] integer type_id     网站分类ID     * @param [type] string type         网站类型 PHP/JAVA     * @param [type] string version      PHP版本 73/74     * @param [type] string port         网站端口     * @param [type] string ps           网站备注     * @param [type] bool ftp            是否创建FTP     * @param [type] string ftp_username  FTP用户名 // ftp为true必传     * @param [type] string ftp_password  FTP密码  // ftp为true必传     * @param [type] bool sql            是否创建数据库     * @param [type] string codeing      数据库编码类型 utf8|utf8mb4|gbk|big5  // sql为true必传     * @param [type] string datauser     数据库账号 // sql为true必传     * @param [type] string datapassword 数据库密码 // sql为true必传     * @return false|int     */    public function AddSite(string $domain)    {        $data = [            "webname" => json_encode([                "domain" => $domain,                "domainlist" => [],                "count" => 0            ]),            "path" => config("custom.bt.site_path"),            "type_id" => "0",            "type" => "PHP",            "version" => "74",            "port" => "80",            "ps" => $domain,            "ftp" => "false",            "sql" => "false"        ];        $response = $this->sendRequest("/site?action=AddSite", $data);        return (isset($response["siteStatus"]) && $response["siteStatus"] === true) ? (int)$response["siteId"] : false;    }    /**     * 删除网站     * @param string $siteName 网站名称 一般是网站域名     * @return bool     */    public function DeleteSite(string $siteName): bool    {        $site = $this->SiteSearch($siteName);        $response = $this->sendRequest("/site?action=DeleteSite", [            "id" => $site["id"],            "webname" => $site["name"]        ]);        return isset($response["status"]) && $response["status"] === true;    }    /**     * 开启网站     * @param string $siteName 网站名称 一般是网站域名     * @return bool     */    public function SiteStart(string $siteName): bool    {        $site = $this->SiteSearch($siteName);        $response = $this->sendRequest("/site?action=SiteStart", [            "id" => $site["id"],            "name" => $site["name"]        ]);        return isset($response["status"]) && $response["status"] === true;    }    /**     * 关闭网站     * @param string $siteName 网站名称 一般是网站域名     * @return bool     */    public function SiteStop(string $siteName): bool    {        $site = $this->SiteSearch($siteName);        $response = $this->sendRequest("/site?action=SiteStop", [            "id" => $site["id"],            "name" => $site["name"]        ]);        return isset($response["status"]) && $response["status"] === true;    }    /**     * 为网站绑定域名     * @param string $siteName 网站名称 一般是网站域名     * @param string $domain 需要绑定的域名     * @return bool     */    public function AddDomain(string $siteName, string $domain)    {        $site = $this->SiteSearch($siteName);        $response = $this->sendRequest("/site?action=AddDomain", [            "id" => $site["id"],            "webname" => $site["name"],            "domain" => $domain        ]);        // 绑定成功 status === true        // 绑定失败 和 指定域名已绑定过  都返回 status === false        // 不好区分 失败 还是 域名已绑定        return isset($response["status"]);    }    /**     * 删除网站绑定的域名     * @param string $siteName 网站名称 一般是网站域名     * @param string $domain 需要删除的域名     * @return bool     */    public function DelDomain(string $siteName, string $domain)    {        $site = $this->SiteSearch($siteName);        $response = $this->sendRequest("/site?action=DelDomain", [            "id" => $site["id"],            "webname" => $site["name"],            "port" => "80",            "domain" => $domain        ]);        return isset($response["status"]) && $response["status"] === true;    }    /**     * 网站设置SSL证书     * @param string $domain 站点域名     * @param string $key     * @param string $csr     * @return bool     */    public function SetSSL(string $domain, string $key, string $csr): bool    {        $data = [            "type" => 1,            "siteName" => $domain,            "key" => "",            "csr" => ""        ];        $response = $this->sendRequest("/site?action=SetSSL", $data);        return isset($response["status"]) && $response["status"] === true;    }    /**     * 获取SSL状态及证书详情     * @param string $domain 站点域名     * @return string|false 成功则返回证书到期时间     */    public function GetSSL(string $domain)    {        $data = [            "siteName" => $domain        ];        $response = $this->sendRequest("/site?action=GetSSL", $data);        return (isset($response["status"]) && $response["status"] === true && $response["cert_data"]) ? $response["cert_data"]["notAfter"] : false;    }    /**     * 设置网站运行目录     * @param int $siteId 站点域名     * @param string $runPath 运行目录路径     * @return bool     */    public function SetSiteRunPath(int $siteId, string $runPath = "/public"): bool    {        $data = [            "id" => $siteId,            "runPath" => $runPath        ];        $response = $this->sendRequest("/site?action=SetSiteRunPath", $data);        return isset($response["status"]) && $response["status"] === true;    }    /**     * 获取网站预置伪静态规则内容(文件内容)     * @param string $domain 网站域名     * @param [type] $type 0->获取内置伪静态规则 /www/server/panel/rewrite/nginx/xxxxx.conf;1->获取当前站点伪静态规则 /www/server/panel/vhost/rewrite/www.baidu.com.conf     * @return string|false 成功则返回伪静态规则内容     */    public function GetFileBody(string $domain)    {        $data = [            "path" => "/www/server/panel/vhost/rewrite/$domain.conf"        ];        $response = $this->sendRequest("/files?action=GetFileBody", $data);        return (isset($response["status"]) && $response["status"] === true) ? $response["data"] : false;    }    /**     * 保存网站伪静态规则内容(保存文件内容)     * 0->系统默认路径;1->自定义全路径     * @param string $domain     * @param string|null $htaccess     * @return bool     */    public function SaveFileBody(string $domain, string $htaccess = null): bool    {        $htaccess = $htaccess ?: config("custom.bt.htaccess");        $data = [            "path" => "/www/server/panel/vhost/rewrite/$domain.conf", // 伪静态文件路径            "data" => $htaccess, // 伪静态规则内容 ==> 字符串            "encoding" => "utf-8"        ];        $response = $this->sendRequest("/files?action=SaveFileBody", $data);        return isset($response["status"]) && $response["status"] === true;    }    /**     * 网站申请并设置SSL证书     * !!!PS:当前请求比较耗时间 20s-60s不等  最好单独使用     * @param int $id 站点ID     * @param string $domain 需要申请的域名     * @return bool|integer     */    public function GetApplyCert(int $id, string $domain)    {        $data = [            "domains" => json_encode([$domain]),            "auth_type" => "http",            "auto_wildcard" => 0,            "auth_to" => $id,            "id" => $id,            "siteName" => $domain        ];        $response = $this->sendRequest("/acme?action=apply_cert_api", $data);//        $response = [//            "cert" => "",//            "root" => "",//            "private_key" => "",//            "cert_timeout" => 1679184499,//            "status" => true//        ];        if (isset($response["status"]) && $response["status"] === true) {            Storage::put("ssl/$domain.txt", json_encode($response));            $res = $this->SetSSL($domain, $response["private_key"], $response["cert"] . $response["root"]);            return $res ? $response["cert_timeout"] : false;        }        return false;    }}

推荐学习:《laravel视频教程》《宝塔使用教程》

以上就是分享Laravel是怎么操作宝塔面板API的详细内容,更多请关注php中文网其它相关文章!

关键词: Laravel 宝塔面板